package simple.array;

import java.util.Arrays;

/**
 * <a href="https://leetcode.cn/problems/relative-ranks/">506. 相对名次</a>
 * 给你一个长度为 n 的整数数组 score ，其中 score[i] 是第 i 位运动员在比赛中的得分。所有得分都 互不相同 。
 *
 * 运动员将根据得分 决定名次 ，其中名次第 1 的运动员得分最高，名次第 2 的运动员得分第 2 高，依此类推。运动员的名次决定了他们的获奖情况：
 *
 * 名次第 1 的运动员获金牌 "Gold Medal" 。
 * 名次第 2 的运动员获银牌 "Silver Medal" 。
 * 名次第 3 的运动员获铜牌 "Bronze Medal" 。
 * 从名次第 4 到第 n 的运动员，只能获得他们的名次编号（即，名次第 x 的运动员获得编号 "x"）。
 * 使用长度为 n 的数组 answer 返回获奖，其中 answer[i] 是第 i 位运动员的获奖情况。
 * 示例 1：
 *   输入：score = [5,4,3,2,1]
 *   输出：["Gold Medal","Silver Medal","Bronze Medal","4","5"]
 *   解释：名次为 [1st, 2nd, 3rd, 4th, 5th] 。
 * 示例 2：
 *   输入：score = [10,3,8,9,4]
 *   输出：["Gold Medal","5","Bronze Medal","Silver Medal","4"]
 *   解释：名次为 [1st, 5th, 3rd, 2nd, 4th] 。
 * 提示：
 *   n == score.length
 *   1 <= n <= 10^4
 *   0 <= score[i] <= 10^6
 *   score 中的所有值 互不相同
 * @author 刘学松
 * @date 2023-05-19 9:07
 */
public class 相对名次 {
    public String[] findRelativeRanks(int[] score) {
        int max = -1, length = score.length;
        for (int i : score) {
            if (i > max) {
                max = i;
            }
        }
        int[] indexes = new int[max+1];
        Arrays.fill(indexes, -1);
        for (int i = 0; i < length; i++) {
            indexes[score[i]] = i;
        }
        String[] answer = new String[length];
        int count = 1;
        for (int i = indexes.length-1; i >= 0; i--) {
            int index = indexes[i];
            if (index > -1) {
                if (count==1) {
                    answer[index] = "Gold Medal";
                } else if (count==2) {
                    answer[index] = "Silver Medal";
                } else if (count==3) {
                    answer[index] = "Bronze Medal";
                } else {
                    answer[index] = String.valueOf(count);
                }
                ++count;
            }
        }
        return answer;
    }
}
